草庐IT

python - 部署 Flask,并行请求

全部标签

Ruby:使用 JSON 正文 PUT 请求?

我需要使用ruby​​创建一个HTTPPUT请求。请求有一个JSON正文我能够使用以下方法生成JSON正文:require'rubygems'require'json'jsonbody=JSON.generate["message"=>"test","user"=>"user1"]我需要将此PUT请求发送到url:require'open-uri'url=URI.parse('http://www.data.com?access_token=123')谁能告诉我如何在Ruby中做到这一点? 最佳答案 像这样使用restclient(

ruby-on-rails - 具有不同 HTTP 请求类型的两个路由如何共享相同的名称?

在Rails3.2中,我使用这些路由声明:get'contact'=>'contact#new',:as=>'contact'post'contact'=>'contact#create',:as=>'contact'它们导致(rakeroutes):contact_enGET/en/contact(.:format)contact#new{:locale=>"en"}contact_deGET/de/kontakt(.:format)contact#new{:locale=>"de"}contact_enPOST/en/contact(.:format)contact#create{

ruby-on-rails - Rails - 部署后无效的真实性 token

我们正在使用EngineYardCloud部署我们的RubyonRails应用程序。我们正在运行Railsv2.3.3。EngineYardCloud以类似于Capistrano的方式部署到AWS实例。每次部署后,我们都会遇到InvalidAuthenticityToken错误。具体来说,任何以前访问过我们的应用程序然后在部署后访问并尝试提交表单的用户都会收到无效的真实性token错误。此错误一直存在,直到他们为网站重置cookie。在他们重置cookie后,该网站按预期运行,没有错误。我们正在使用ActiveRecord的session存储并将session保存到数据库中。这是我们看

ruby-on-rails - 如何在 Ruby 2 中为 Net::HTTP::Post.new 请求指定读取超时

我有一个帖子发生在一个ruby​​脚本的rails应用程序上。该脚本创建一个变量请求作为request=Net::HTTP::Post.new(url.path)然后按如下方式使用request.content_type="application/json"request.body=JSON.generate(params)response=Net::HTTP.start(url.host,url.port){|http|http.request(request)}服务器端发生了相当多的处理,我收到了一个Net::ReadTimeout错误我尝试指定超时时间request.read_t

ruby-on-rails - 部署时 "Warm Up Cache"

我想知道是否有人有任何插件或capistrano配方可以通过在部署时或在本地部署之前构建所有页面缓存的html来“预热”rails应用程序的页面缓存。我有一些主要是静态的网站,它们变化不大,如果已经编写了html,运行速度会更快,而不是要求一位访问者访问该网站。与其自己创建它(看起来很简单,但它的优先级很低),它是否已经存在? 最佳答案 您可以使用wget或其他程序来抓取站点。事实上,这种场景在其手册页中被提及为一种用途:ThisoptiontellsWgettodeleteeverysinglefileitdownloads,af

ruby - 如何在 Ruby 中发送 HTTP PUT 请求?

我正在尝试向特定URL发送PUT请求,但迄今为止未能成功。如果我是通过一个HTTP请求者GUI来做的,比如this第一,它就像在以下url上执行PUT一样简单:http://www.mywebsite.com:port/Application?key=apikey&id=id&option=enable|disable请注意,在上述请求中指定了一个端口号。在通过ruby​​代码提交请求时,我也需要这样做。如何在Ruby中复制这样的请求? 最佳答案 require'net/http'port=8080host="127.0.0.1"p

ruby - Ruby 中的并行赋值运算符

我正在看《ProgramminginRuby》一书中的一个例子:deffib_up_to(max)i1,i2=1,1#parallelassignment(i1=1andi2=1)whilei1这只是打印斐波那契数达100。没问题。当我将并行分配替换为:i1=i2i2=i1+i2我没有得到想要的输出。是否建议使用并行分配?我来自Java背景,看到这种类型的分配感觉真的很奇怪。还有一个问题是:并行赋值是运算符吗? 最佳答案 在2个单独的语句中进行赋值的问题是i2=i1+i2将使用i1的新值而不是正确要求的先前值生成斐波那契数列。当您使

ruby-on-rails - 使用 net/http 发送 Post 请求

我需要将JSON格式的数据发送到在同一台计算机上运行的另一个应用程序。我这样发送请求(rails3.2.13)data={//somedatahash}url=URI.parse('http://localhost:6379/api/plans')resp,data=Net::HTTP.post_form(url,data.to_JSON)presppdata{resp:resp,data:data.to_JSON}但我得到Net::HTTPBadResponse(错误的状态行:“-ERR未知命令‘POST’”):我怎么解决这个问题?更新1按照@Raja-d的建议更新了我的代码url=

ruby-on-rails - 在某些 RSpec rails 请求示例中测试 HTTP 状态代码,但在其他示例中测试引发的异常

在使用rspec-rails测试的Rails4.2.0应用程序中,我提供了一个JSONWebAPI,它带有一个类似REST的资源,带有强制属性mand_attr.当POST请求中缺少该属性时,我想测试此API是否使用HTTP代码400(BADREQUEST)进行响应。(参见下图第二个示例。)我的Controller尝试通过抛出ActionController::ParameterMissing来引发此HTTP代码,如下面的第一个RSpec示例所示。在otherRSpec示例中,我希望引发的异常被示例拯救(如果它们是预期的)或击中测试运行器,所以它们显示给开发人员(如果错误是意外的),因

ruby - 在其自己的目录之外运行 bundler 部署的 Ruby 应用程序?

我正在编写一个基于Ruby的守护程序,以便在我的一台Ubuntu服务器上运行。我希望它在启动时运行,因此将为它编写一个upstart作业文件。但是,我使用bundler来管理它使用的各种gem,并打算在将它部署到服务器后执行此操作:bundleinstall--deployment这会将bundler置于所谓的“部署模式”,从而设置各种选项并将所有gem安装到“供应商”目录而不是系统范围内。然而,这会在运行时产生问题,因此它必须从其自己的目录中执行,因为这是gems的最终位置:$./runmyapp如果我cd到一个不同的位置,然后尝试使用它的完整路径运行它,它会失败:$/path/to